Named Query এবং Native SQL Query গাইড ও নোট

Java Technologies - হাইবারনেট (Hibernate) - Hibernate Query Language (HQL)
359

Hibernate (হাইবারনেট) একটি ORM (Object-Relational Mapping) ফ্রেমওয়ার্ক যা Java অ্যাপ্লিকেশন ডেভেলপমেন্টের জন্য ব্যবহৃত হয়। Hibernate আপনাকে Named Query এবং Native SQL Query এর মাধ্যমে ডেটাবেস থেকে ডেটা আহরণের জন্য কুয়েরি চালানোর সুবিধা প্রদান করে।

নিচে Named Query এবং Native SQL Query সম্পর্কিত বিস্তারিত আলোচনা করা হয়েছে।


1. Named Query

Named Query Hibernate-এর একটি শক্তিশালী বৈশিষ্ট্য, যা আপনাকে পূর্ব-সংজ্ঞায়িত (predefined) SQL বা HQL (Hibernate Query Language) কুয়েরি সংরক্ষণ করতে সহায়তা করে। এর মাধ্যমে আপনি কুয়েরি রিচুয়াল এবং ফিচারের জন্য কোড পুনঃব্যবহারযোগ্যতা এবং কনভেনিয়েন্স অর্জন করতে পারেন। Named Query সাধারণত হাইবারনেট @NamedQuery অ্যানোটেশন বা XML কনফিগারেশনের মাধ্যমে তৈরি করা হয়।

Named Query এর ব্যবহার:

  1. HQL Named Query: Hibernate-এ HQL ব্যবহার করে একটি Named Query তৈরি করা হয়। HQL হল Hibernate-এর কুয়েরি ভাষা, যা SQL এর মতো হলেও এটি Java objects (Entity classes) এবং তাদের অ্যাসোসিয়েশনগুলির সাথে কাজ করে।

Named Query তৈরি করা:

import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.NamedQuery;

@Entity
@NamedQuery(name = "User.findByName", query = "FROM User u WHERE u.name = :name")
public class User {
    @Id
    private int id;
    private String name;
    private String email;

    // Getters and Setters
}

এখানে, @NamedQuery ব্যবহার করা হয়েছে যা User ক্লাসের মধ্যে findByName নামে একটি named query তৈরি করে। এই কুয়েরি User টেবিল থেকে সেই ইউজারের ডেটা বের করবে যাদের নাম :name প্যারামিটার সমান।

Named Query ব্যবহার করা:

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

public class HibernateNamedQueryExample {
    public static void main(String[] args) {
        SessionFactory factory = new Configuration().configure("hibernate.cfg.xml")
                .addAnnotatedClass(User.class)
                .buildSessionFactory();

        Session session = factory.getCurrentSession();

        try {
            // Start a transaction
            session.beginTransaction();

            // Execute Named Query
            String name = "John Doe";
            User user = (User) session.createNamedQuery("User.findByName")
                                      .setParameter("name", name)
                                      .uniqueResult();

            // Display the result
            System.out.println("User found: " + user);

            session.getTransaction().commit();
        } finally {
            factory.close();
        }
    }
}

এখানে, createNamedQuery() পদ্ধতি ব্যবহার করে Named Query চালানো হয়েছে এবং প্যারামিটার হিসেবে ইউজারের নাম পাঠানো হয়েছে।

Named Query এর সুবিধা:

  • Reusability: একই কুয়েরি একাধিক জায়গায় ব্যবহার করা যায়।
  • Maintainability: কুয়েরি এক জায়গায় সংরক্ষিত থাকে, পরিবর্তন করা সহজ হয়।
  • Performance: Hibernate কুয়েরি কম্পাইল এবং অপটিমাইজ করে, যা কর্মক্ষমতা বৃদ্ধি করতে সাহায্য করে।

2. Native SQL Query

Hibernate-এ Native SQL Query ব্যবহার করলে আপনি সরাসরি ডেটাবেসে নির্দিষ্ট SQL কুয়েরি চালাতে পারেন। এই কুয়েরি ডেটাবেস নির্দিষ্ট (Database-specific) হতে পারে, এবং Hibernate এর HQL থেকে ভিন্ন, এটি ডেটাবেসের actual SQL সিন্দৃশ (syntax) অনুসরণ করে। Hibernate আপনাকে Native SQL কুয়েরি চালানোর জন্য createSQLQuery() পদ্ধতি সরবরাহ করে।

Native SQL Query এর উদাহরণ:

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

public class HibernateNativeQueryExample {
    public static void main(String[] args) {
        SessionFactory factory = new Configuration().configure("hibernate.cfg.xml")
                .addAnnotatedClass(User.class)
                .buildSessionFactory();

        Session session = factory.getCurrentSession();

        try {
            // Start a transaction
            session.beginTransaction();

            // Execute Native SQL Query
            String sql = "SELECT * FROM users WHERE name = :name";
            User user = (User) session.createSQLQuery(sql)
                                      .addEntity(User.class)
                                      .setParameter("name", "John Doe")
                                      .uniqueResult();

            // Display the result
            System.out.println("User found: " + user);

            session.getTransaction().commit();
        } finally {
            factory.close();
        }
    }
}

এখানে, createSQLQuery() পদ্ধতি ব্যবহার করে একটি Native SQL Query চালানো হয়েছে, যা ডেটাবেসের users টেবিল থেকে ইউজারের তথ্য নিয়ে আসে।

Native SQL Query এর সুবিধা:

  • Database-specific functionality: Native SQL ব্যবহার করার মাধ্যমে ডেটাবেসের নির্দিষ্ট কার্যকারিতা, ফাংশন এবং অপ্টিমাইজেশান সুবিধা পাওয়া যায়।
  • Direct SQL Execution: Hibernate কেবল SQL কুয়েরি পরিচালনা করে, তাই এটি ডেটাবেসের সঙ্গে সরাসরি কাজ করতে সক্ষম।
  • Complex Queries: যখন HQL সীমাবদ্ধতা থাকে, তখন Native SQL এর মাধ্যমে আরও জটিল কুয়েরি তৈরি করা যায়।

Native SQL Query এর কিছু সীমাবদ্ধতা:

  • Database Dependency: Native SQL ডেটাবেস নির্দিষ্ট, তাই আপনার অ্যাপ্লিকেশনটি একাধিক ডেটাবেসে চলে না।
  • Less Abstraction: Hibernate এর object-relational mapping সুবিধা Native SQL এ পাওয়া যায় না, যেমন Hibernate এ Entity ফিচারের সাথে সম্পর্কিত কাজ।

Named Query vs Native SQL Query:

CriteriaNamed QueryNative SQL Query
LanguageHQL (Hibernate Query Language)Actual SQL (Database-specific SQL syntax)
Abstraction LevelHigh abstraction (works with Java objects)Low abstraction (works with raw SQL and database tables)
Database IndependenceDatabase-independent (works across different DBs)Database-specific (depends on the DB's SQL syntax)
ComplexitySimpler for basic queriesSuitable for complex or database-specific queries
PerformanceMay be less optimized in certain casesOptimized for specific database features
Use CaseSuitable for object-based queriesSuitable for database-specific queries (complex joins, functions)

Hibernate-এ Named Query এবং Native SQL Query দুটোই গুরুত্বপূর্ণ এবং কার্যকরী কুয়েরি প্রক্রিয়া, তবে তাদের ব্যবহার পরিস্থিতির ওপর নির্ভর করে। Named Query সাধারণত ব্যবহৃত হয় যখন আপনি ডেটাবেসের অযথা নির্দিষ্ট SQL সিনট্যাক্স থেকে অবাধ থাকতে চান, এবং Native SQL তখন ব্যবহার করা হয় যখন আপনার ডেটাবেসের নির্দিষ্ট ক্ষমতাগুলি যেমন complex joins, stored procedures ইত্যাদি ব্যবহার করতে হয়।

Content added By
Promotion

Are you sure to start over?

Loading...